# PDP-11 Phase 1

#### **Team Number** 3

### **Team Members**

**Ahmed Mostafa** 

Seif El Din El Said

**Omar Ibrahim** 

Naiera Magdy

## **Bus System Schematic:**



## **Instruction Set Architecture:**

## • 2-Operands Instructions:

|           | Оро | code | )  | src |    |   |   | dst |   |   |   |   |   |   |   |
|-----------|-----|------|----|-----|----|---|---|-----|---|---|---|---|---|---|---|
| <b>15</b> | 14  | 13   | 12 | 11  | 10 | 9 | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

| Instruction | Op code (Binary) |
|-------------|------------------|
| MOV         | 0000             |
| ADD         | 0001             |
| ADC         | 0010             |
| SUB         | 0011             |
| SBC         | 0100             |
| AND         | 0101             |
| OR          | 0110             |
| XOR         | 0111             |
| CMP         | 1000             |

## • 1-Operand Instructions:

| OP code |    |    |    |    |    |   |   |   |   |   | dst |   |   |   |   |
|---------|----|----|----|----|----|---|---|---|---|---|-----|---|---|---|---|
| 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3 | 2 | 1 | 0 |

| Instruction | Op code (Binary) |
|-------------|------------------|
| INC         | 1001 00 0000     |
| DEC         | 1001000100       |
| CLR         | 100100 1000      |
| INV         | 100100 1100      |
| LSR         | 1001010000       |
| ROR         | 1001010100       |
| ASR         | 100101 1000      |
| LSL         | 1001011100       |
| ROL         | 1001 10 0000     |

#### • Branch Instructions:

|    |    | C  | )P c | ode |    |   |   | Offset |   |   |   |   |   |   |   |
|----|----|----|------|-----|----|---|---|--------|---|---|---|---|---|---|---|
| 15 | 14 | 13 | 12   | 11  | 10 | 9 | 8 | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

| Instruction | Op code (Binary) |
|-------------|------------------|
| BR          | 1010 0000        |
| BEQ         | 1010 0001        |
| BNE         | 1010 0010        |
| BLO         | 1010 0011        |
| BLS         | 1010 0100        |
| BHI         | 1010 0101        |
| BHS         | 1010 0110        |

## • No Operand Instructions:

|    | OP code |    |    |  |  |  |  |  |
|----|---------|----|----|--|--|--|--|--|
| 15 | 14      | 13 | 12 |  |  |  |  |  |

| Instruction | Op code (Binary) |
|-------------|------------------|
| BR          | 1011             |
| BEQ         | 1011             |
| BNE         | 1011             |

#### • Subroutine Instructions:

|    |    |    | CO |    |    |   |
|----|----|----|----|----|----|---|
| 15 | 14 | 13 | 12 | 11 | 10 | 9 |

| Instruction | Op code (Binary) |
|-------------|------------------|
| JSR         | 1110 000         |
| RTS         | 1110 001         |
| INT         | 1110 010         |
| IRET        | 1110 011         |

# **Addressing Modes:**

| b5b4b3 | Name                   | Syntax |
|--------|------------------------|--------|
| 000    | Register Direct        | Rn     |
| 010    | Autoincrement          | (Rn)+  |
| 100    | Autodecrement          | -(Rn)  |
| 110    | <b>Index Direct</b>    | X(Rn)  |
| 001    | Register indirect      | @Rn    |
| 011    | Autoincrement indirect | @(Rn)+ |
| 101    | Autodecrement indirect | @-(Rn) |
| 111    | Index indirect         | @X(Rn) |

## **Micro-Instructions:**

#### • Words:

| F1 4<br>BITS |                | F2 3<br>BITS |                | F3 2<br>BITS |                | F4 1<br>BIT |                | F5 4<br>BITS |     |
|--------------|----------------|--------------|----------------|--------------|----------------|-------------|----------------|--------------|-----|
| "0000"       | No<br>Transfer | "000"        | No<br>Transfer | "00"         | No<br>transfer | "0"         | No<br>transfer | "0000"       | ADD |
| "0001"       | PC out         | "001"        | Pc in          | "01"         | MAR in         | "1"         | Yin            | "0001"       | ADC |
| "0010"       | MDR out        | "010"        | IR in          | "10"         | MDR in         |             |                | "0010"       | SUB |
| "0011"       | Z out          | "011"        | Zin            |              |                |             |                | "0011"       | SBC |
| "0100"       | RSrc out       | "100"        | RSrc in        |              |                |             |                | "0100"       | AND |
| "0101"       | RDst out       | "101"        | RDst in        |              |                |             |                | "0101"       | OR  |
| "0110"       | Temp out       | "110"        | Temp in        |              |                |             |                | "0110"       | XOR |
| "0111"       | Address out    | "111"        | Branch         |              |                |             |                | "0111"       | INV |
| "1000"       | HLT            |              |                |              |                |             |                | "1000"       | LSR |
| "1001"       | RESET          |              |                |              |                |             |                | "1001"       | ROR |
|              |                |              |                |              |                |             |                | "1010"       | ASR |
|              |                |              |                |              |                |             |                | "1011"       | LSL |
|              |                |              |                |              |                |             |                | "1100"       | ROL |
|              |                |              |                |              |                |             |                | "1101"       | INC |
|              |                |              |                |              |                |             |                | "1110"       | DEC |
|              |                |              |                |              |                |             |                | "1111"       | MOV |

| F6 2<br>BITS |              | F7 1<br>BIT |              | F8 1<br>BIT |                | F9 1<br>BIT |            | F10 1<br>BIT |          |
|--------------|--------------|-------------|--------------|-------------|----------------|-------------|------------|--------------|----------|
| "00"         | No<br>action | "0"         | No<br>action | "0"         | Carry-<br>in=0 | "0"         | No actions | "0"          | Continue |
| "01"         | Read         | "1"         | Clear Y      | "1"         | Carry-<br>in=1 | "1"         | WMFC       | "1"          | END      |
| "10"         | Write        |             |              |             |                |             |            |              |          |
| "11"         | uBranch      |             |              |             |                |             |            |              |          |